تركيب الحاسوب

**Ghufran Saady** 

# Computer Organization and Architecture Computer

- ▶ technology has made incredible improvement in the past half century. In the early part of computer evolution, there were no stored-program computer, the computational power was less and on the top of it the size of the computer was a very huge one.
- Today, a personal computer has more computational power, more main memory, more disk storage, smaller in size and it is available in effordable cost. This rapid rate of improvement has come both from advances in the technology used to build computers and from innovation in computer design. In this course we will mainly deal with the innovation in computer design.
- ▶ The task that the computer designer handles is a complex one: Determine what attributes are important for a new machine, then design a machine to maximize performance while staying within cost constraints. This task has many aspects, including instruction set design, functional organization, logic design, and implementation. While looking for the task for computer design, both the terms computer organization and computer architecture come into picture.

### Introduction

- ► It is difficult to give precise definition for the terms Computer Organization and Computer Architecture. But while describing computer system, we come across these terms, and in literature, computer scientists try to make a distinction between these two terms.
- Computer architecture refers to those parameters of a computer system that are visible to a programmer or those parameters that have a direct impact on the logical execution of a program. Examples of architectural attributes include the instruction set, the number of bits used to represent different data types, I/O mechanisms, and techniques for addressing memory.
- Computer organization refers to the operational units and their interconnections that realize the architectural specifications. Examples of organizational attributes include those hardware details transparent to the programmer, such as control signals, interfaces between the computer and peripherals, and the memory technology used.

| • | The model of a computer can be described by four basic  |
|---|---------------------------------------------------------|
|   | units in high level abstraction. These basic units are: |

- O Central Processor Unit
- O Input Unit
- O Output Unit
- O Memory Unit

#### A. Central Processor Unit [CPU] :

- Central processor unit consists of :
- control unit has a set of registers and control circuit to generate control signals.
- Arithmatic and Logic Unit (ALU) for execution of arithmatic and logical operations.
- In addition, CPU may have some additional registers for temporary storage of data.

#### B. Input Unit:

With the help of input unit data from outside can be supplied to the computer. Program or data is read into main storage from input device or secondary storage under the control of CPU input instruction. Example of input devices: Keyboard, Mouse, Hard disk, Floppy disk, CD-ROM drive etc.

#### C. Output Unit :

- With the help of output unit computer results can be provided to the user or it can be stored in storage device permanently for future use. Output data from main storage go to output device under the control of CPU output instructions.
- Example Printer, Monitor, Plotter, Hard Disk, Floppy Disk etc.

#### D. Memory Unit :

 Memory unit is used to store the data and program. CPU can work with the information stored in memory unit. This memory unit is termed as primary memory or main memory module. These are basically semi conductor memories.

### Basic computer (cont.)

- There are two types of semiconductor memories
- Volatile Memory : RAM (Random Access Memory).
- Non-Volatile Memory: ROM (Read only Memory), PROM (Programmable ROM) EPROM (Erasable PROM), EEPROM (Electrically Erasable PROM).

#### Secondary Memory :

- There is another kind of storage device, apart from primary or main memory, which is known as secondary memory. Secondary memories are non volatile memory and it is used for permanent storage of data and program.
- Example of secondary memories:
- Hard Disk, Floppy Disk, Magenetic Tape: These are magnetic devices,
- CD-ROM is optical device
- Thumb drive (or pen drive) is semiconductor memory.

- First Generation (1940-1950) :: Vacuum Tube
- Electron emitting devices
- Data and programs are stored in a single read-write memory
- Memory contents are addressable by location, regardless of the content itself
- Machine language/Assemble language
- Sequential execution

#### **Second Generation (1950-1964) :: Transistors**

- William Shockley, John Bardeen, and Walter Brattain invent the transistor that reduce size of computers and improve reliability. Vacuum tubes have been replaced by transistors.
- First operating Systems: handled one program at a time
- On-off switches controlled by electronically.
- High level languages
- Floating point arithmetic

# Third Generation (1964-1974) :: Integrated Circuits (IC)

- Microprocessor chips combines thousands of transistors, entire circuit on one computer chip.
- Semiconductor memory
- Multiple computer models with different performance characteristics
- The size of computers has been reduced drastically

- ► Fourth Generation (Very Large-Scale Integration (VLSI) / Ultra Large Scale Integration
- Combines millions of transistors
- Single-chip processor and the single-board computer emerged
- Creation of the Personal Computer (PC)
- Use of data communications
- Massively parallel machine

#### The von Neumann Model

The invention of stored program computers has been ascribed to a mathematician, John von Neumann, who was a contemporary of Mauchley and Eckert.

Stored-program computers have become known as **von Neumann Architecture** systems.

- Today's stored-program computers have the following characteristics:
  - Three hardware systems:
    - A central processing unit (CPU)
    - A main memory system
    - An I/O system
  - The capacity to carry out sequential instruction processing.
  - A single data path between the CPU and main memory.
    - This single path is known as the von Neumann bottleneck.

This is a general depiction of a von Neumann system:

These computers employ a fetch-decode-execute cycle to run programs as follows . . .



The control unit fetches the next instruction from memory using the program counter to determine where the instruction is located.



The instruction is decoded into a language that the ALU can understand.



Any data operands required to execute the instruction are fetched from memory and placed into registers within the CPU.



# The ALU executes the instruction and places results in registers or memory



Conventional stored-program computers have undergone many incremental improvements over the years.

These improvements include adding specialized buses, floating-point units, and cache memories, to name only a few.

But enormous improvements in computational power require departure from the classic von

- In the late 1960s, high-performance computer systems were equipped with dual processors to increase computational throughput.
- In the 1970s supercomputer systems were introduced with 32 processors.
- Supercomputers with 1,000 processors were built in the 1980s.
- In 1999, IBM announced its Blue Gene system
   containing over 1 million processors

 Parallel processing is only one method of providing increased computational power.

 DNA computers, quantum computers, and dataflow systems. At this point, it is unclear whether any of these systems will provide the basis for the next generation of computers.

Leonard Adleman is often called the inventor of DNA computers. His article in a 1994 issue of the journal Science outlined how to use DNA to solve a well-known mathematical problem, called the "traveling salesman" problem. The goal of the problem is to find the shortest route between a number of cities, going through each city only once. As you add more cities to the problem, the problem becomes more difficult. Adleman

# Multiplexers

log<sub>2</sub>n selection inputs



- multiplexer
  - n binary inputs (binary input = 1-bit input)
  - log<sub>2</sub>n binary selection inputs
  - 1 binary output
  - Function: one of n inputs is placed onto output
  - Called n-to-1 multiplexer

## 2-to-1 Multiplexer



(a) Graphical symbol



(b) Truth table



(c) Sum-of-products circuit



(d) Circuit with transmission gates

Source: Brown and Vranesic

# 4-to-1 Multiplexer



- (a) Graphic symbol
- (b) Truth table



Source: Brown and Vranesic

(c) Circuit

### **Decoders**



n binary inputs

Decoder

- 2<sup>n</sup> binary outputs
- Function: decode encoded information
  - If enable=1, one output is asserted high, the other outputs are asserted low
  - If enable=0, all outputs asserted low
- Often, enable pin is not needed (i.e. the decoder is always enabled)
- Called n-to-2<sup>n</sup> decoder
  - Can consider n binary inputs as a single n-bit input
  - Can consider 2<sup>n</sup> binary outputs as a single 2<sup>n</sup>-bit output
- Decoders are often used for RAM/ROM addressing

### 2-to-4 Decoder

| Er | 7Щ | ив | Уз | <i>y</i> <sub>2</sub> | У1 | Ж |
|----|----|----|----|-----------------------|----|---|
| 1  | 0  | 0  | 0  | 0                     | 0  | 1 |
| 1  | 0  | 1  | 0  | 0                     | 1  | 0 |
| 1  | 1  | 0  | 0  | 1                     |    | 0 |
| 1  | 1  | 1  | 1  | 0                     |    |   |
| 0  | -  | -  | 0  | 0                     | 0  | 0 |



(a) Truth table

(b) Graphical symbol



Source: Brown and Vranesic

(c) Logic circuit

## Demultiplexers

log<sub>2</sub>n selection inputs



- Demultiplexer
  - 1 binary input
  - n binary outputs
  - log<sub>2</sub>n binary selection inputs
  - Function: places input onto one of n outputs, with the remaining outputs asserted low
  - Called **1-to-n** demultiplexer
- Closely related to decoder
  - Can build 1-to-n demultiplexer from log<sub>2</sub>n-to-n decoder by using the decoder's enable signal as the demultiplexer's input signal, and using decoder's input signals as the demultiplexer's selection input signals.

### 4-to-2 Encoder

| ИЗ | И2 | щ | иб | <i>Y</i> <sub>1</sub> | Ж |
|----|----|---|----|-----------------------|---|
| 0  | 0  | 0 | 1  | 0                     | 0 |
| 0  | 0  | 1 | 0  | 0                     | 1 |
| 0  | 1  | 0 | 0  | 1                     | 0 |
| 1  | 0  | 0 | 0  | 1                     | 1 |

(a) Truth table



### Comparator

- Used two compare two M-bit numbers and produce a flag (M >1)
  - Inputs: M-bit input A, M-bit input B
  - Output: 1-bit output flag
    - 1 indicates condition is met
    - 0 indicates condition is not met
  - Can compare: >, >=, <, <=, =, etc.</p>



# **Example: 4-bit comparator (A = B)**



#### **Tri-state Buffer**



| e x | f |
|-----|---|
| 0 0 | Z |
| 0 1 | Ζ |
| 1 0 | 0 |
| 1 1 | 1 |



(b) Equivalent circuit

(c) Truth table

### Four types of Tri-state Buffers





## Register



 In typical nomenclature, a register is a name for a collection of flip-flops used to hold a bus (i.e. std\_logic\_vector)

## **Shift Register**





(a) Circuit

|                       | SinQ |   | Q | Q | $Q_1 = Q$ |
|-----------------------|------|---|---|---|-----------|
| Ф                     | 1    | 0 | 0 | 0 | 0         |
| <i>t</i> <sub>1</sub> | 0    | 1 | 0 | 0 | 0         |
| <i>‡</i>              | 1    | 0 | 1 | 0 | 0         |
| ₿                     | 1    | 1 | 0 | 1 | 0         |
| <i>t</i> <sub>4</sub> | 1    | 1 | 1 | 0 | 1         |
| <b>t</b> 5            | 0    | 1 | 1 | 1 | 0         |
| <b>6</b>              | 0    | 0 | 1 | 1 | 1         |
| ħ                     | n    | 0 | 0 | 1 | 1         |

(b) A sample sequence

#### Memory Hierarchy

#### **Main memory**

Should store currently needed program instructions and data only

#### Secondary storage

Stores data and programs that are not actively needed

#### Cache memory

- Extremely high speed
- Usually located on processor itself
- Most-commonly-used data copied to cache for faster access
- Small amount of cache still effective for boosting performance

#### **Memory Hierarchy**



#### - Classification System of Memory



#### Two major types of Memory:

- \* RAM (Read Access Memory)
- i. Perform
- ii. Read
- iii. Write

- \* ROM (Read-Only Memory)
- i. A Programmable logic device
- ii. Perform only the read operation

## Registers associated with the memory system:

Both RAM and ROM can be characterized by two registers and a number of control signals.

- <u>For Example:</u> Consider a memory of 2<sup>n</sup> words, each having M bits. Then,
- the Memory Address Register (MAR) is an n-bit register used to specify the memory address
- The Memory Buffer Register (MBR) is an M-bit register used to hold data to be written to the memory or just read from the memory. This register is also called Memory Data Register (MDR)

# MAR,



#### **RAM**

 Memory is a collection of storage cells with associated input and output circuitry

Possible to read and write cells

- Random access memory (RAM) contains words of information
- Data accessed using a sequence of signals

Leads to timing waveforms

. Decedence on the set sent of

#### **Preliminaries**

- RAMs contain a collection of data bytes
  - A collection of bytes is called a word
    - A sixteen bit word contains two bytes
- Capacity of RAM device is usually described in bytes (e.g. 16 MB)
- Write operations write data to specific words





Fig. 7-1 Conventional and Array Logic Diagrams for OR Gate **3** 

## **RAM Interface Signals**

- Data input and output lines carry data
- Memory contains 2<sup>k</sup> words
  - k address lines
     select one word out
     of 2<sup>k</sup>
- Read asserted



Fig. 7-2 Block Diagram of a Memory Unit

## Random Access Memory Fundamentals

- Lets consider a simple RAM chip
  - 8 words of 2 bytes each (each word is 16 bits)
  - How many address bits do we need?

| Pick c | one of 8 loca | 01010000 111001d Data and Input signals |
|--------|---------------|-----------------------------------------|
| Dec    | Binary        | 11001100 111111111                      |
| 0      | 000           | 00000000 1010 1010 address signals      |
| 1      | 001           | 01010110 0011 1111                      |
| 2      | 010           | 11111111 000000000                      |
| 3      | 011           | 00000001 1000 <mark>0000</mark>         |
| 4      | 100           | <b>01010101 1100</b> 1100               |
| 5      | 101           | 00000000 1111 1111                      |
| 6      | 110           | Word                                    |
| 7      | 111           | Each bit stored in a binary cell        |

### RAM Size

° If memory has 2<sup>k</sup>

| Memory | address |
|--------|---------|
|--------|---------|

| words, k address bare needed                         | IUS Memory a | nddress |                   |
|------------------------------------------------------|--------------|---------|-------------------|
| are needed                                           | Binary       | decimal | Memory contest    |
| ° 2 <sup>3</sup> words, 3<br>address bits            | 0000000000   | 0       | 10110101010111101 |
| addiess bits                                         | 0000000001   | 1       | 1010101110001001  |
| ° Address locations are labelled 0 to 2 <sup>k</sup> | 0000000010   | 2       | 0000110101000110  |
|                                                      | _            | :       | :                 |
| ° Common subscrip                                    | ts:          | •       | :                 |
| ° Kilo − 2 <sup>10</sup>                             | 1111111101   | 1021    | 1001110100010100  |
| о № До 220                                           | 1111111110   | 1022    | 0000110100011110  |
| ° Mega − 2 <sup>20</sup>                             | 1111111111   | 1023    | 1101111000100101  |
| ° Giga - 2 <sup>30</sup>                             |              |         | 1                 |

Fig. 7-3 Content of a  $1024 \times 16$  Memory

### **Write Operation**

1. Apply binary address of word to address lines



Read input signal should be inactive eigram of a Memory Unit input lines

Belay associated with write write input

### **Read Operation**



Fig. 7-2 Block Diagram of a Memory Unit

Memory enable used to allow read and writes

## Types of Random Access Memories

- Static random access memory (SRAM)
  - Operates like a collection of latches
  - Once value is written, it is guaranteed to remain in the memory as long as power is applied
  - Generally expensive
  - Used inside processors (like the Pentium)
- Dynamic random access memory (DRAM)
  - Generally, simpler internal design than SRAM
  - Requires data to be rewritten (refreshed), otherwise data is lost
  - Often hold larger amount of data than SRAM
  - Longer access times than SRAM
  - Used as main memory in computer systems

## Inside the RAM Device

 Address inputs go into decoder

Only one output active

- Word line selects a row of bits (word)
- Data passes through OR gate
- Each binary cell (BC) stores one bit
- Input data stored if Read/Write is 0
- Output data driven if Read/Write is 1



Fig. 7-6 Diagram of a 4 × 4 RAM

#### Inside the SRAM

- **Device**Basis of each SRAM cell is an S-R latch
- Note that data goes to both S and R
- **Select enables operation**
- Read/write enables read or write, but not



Fig. 7-5 Memory Cell

#### Inside the SRAM

 Note: delay primarily depends on the number of words

 Delay not effected by size of words

Input data Word Word 0 BC BC BC BC Address Word 1 inputs BC BC BC BC  $2 \times 4$ decoder Word 2 BC BC BC Memory EN enable Word 3 BC BC BC Read/Write Output data

° How many address bits would I need for 16 words?

Fig. 7-6 Diagram of a 4 × 4 RAM

- If the active portions of the program and data are placed in a fast small memory, the average memory access time can be reduced,
- Thus reducing the total execution time of the program
- Such a fast small memory is referred to as cache memory
- The cache is the fastest component in the memory hierarchy and approaches the speed of CPU component

When CPU needs to access memory, the cache is examined

 If the word is found in the cache, it is read from the fast memory

 If the word addressed by the CPU is not found in the cache, the main memory is accessed to read the word

- When the CPU refers to memory and finds the word in cache, it is said to produce a hit
- Otherwise, it is a miss

- The performance of cache memory is frequently measured in terms of a quantity called hit ratio
- Hit ratio = hit / (hit+miss)

- The basic characteristic of cache memory is its fast access time,
- Therefore, very little or no time must be wasted when searching the words in the cache
- The transformation of data from main memory to cache memory is referred to as a **mapping** process, there are three types of mapping:
  - Associative mapping
  - Direct mapping
  - Set-associative mapping

 To help understand the mapping procedure, we have the following example:



## **Associative mapping**

- The fastest and most flexible cache organization uses an associative memory
- The associative memory stores both the address and data of the memory word
- This permits any location in cache to store any word from main memory
- The address value of 15 bits is shown as a five-digit octal number and its corresponding 12-bit word is shown as a four-digit octal number

## **Associative mapping**



## **Associative mapping**

- A CPU address of 15 bits is places in the argument register and the associative memory use searched for a matching address
- If the address is found, the corresponding 12-bits data is read and sent to the CPU
- If not, the main memory is accessed for the word
- If the cache is full, an address-data pair must be displaced to make room for a pair that is needed and not presently in the cache

## **Direct Mapping**

- Associative memory is expensive compared to RAM
- In general case, there are 2<sup>k</sup> words in cache memory and 2<sup>n</sup> words in main memory (in our case, k=9, n=15)
- The n bit memory address is divided into two fields:
   k-bits for the index and n-k bits for the tag field

## **Direct Mapping**



## **Direct Mapping**

| Memory<br>Address | Memory Data |
|-------------------|-------------|
| 00000             | 1220        |
| 00777             | 2340        |
| 01000             | 3450        |
| 01111             | 2222        |
| 01777             | 4560        |
| 02000             | 5670        |
| 02777             | 6710        |

| Index<br>Addre | _  | Data |
|----------------|----|------|
| 000            | 00 | 1220 |
| 111            | 01 | 2222 |
| 777            | 02 | 6710 |

## **Set-Associative Mapping**

- The disadvantage of direct mapping is that two words with the same index in their address but with different tag values cannot reside in cache memory at the same time
- Set-Associative Mapping is an improvement over the direct-mapping in that each word of cache can store two or more word of memory under the same index address

## **Set-Associative Mapping**

Data

5670

2340

| Memory<br>Address | Memory Data  | Index<br>Address | Tag | Data | Tag |
|-------------------|--------------|------------------|-----|------|-----|
| 00000             | 1220         | 000              | 01  | 3450 | 02  |
|                   |              | 111              | 01  | 2222 |     |
| 00777<br>01000    | 2340<br>3450 |                  |     |      |     |
| 01111             | 2222         | 777              | 02  | 6710 | 00  |
| 01777<br>02000    | 4560<br>5670 |                  |     |      |     |
| 02777             | 6710         |                  |     |      |     |

## **Set-Associative Mapping**

- In the slide, each index address refers to two data words and their associated tags
- Each tag requires six bits and each data word has 12 bits, so the word length is 2\*(6+12) = 36 bits

## **Cash Memory Example:**

- Processors use 2 levels of cache
- Example used is a Intel 2800 MHz
  - Level 1 (also called Primary)
    - Very small amount of cache 12kb
    - Fastest Memory
    - Stores recently used data and instructions
  - Level 2 (also called secondary)
    - 512Kb
    - Faster than main memory, but slower than Level1
    - Stores what can not fit into the smaller Level 1
       Cache

# and L2 cache memories in a computer system.



#### **CONTROL UNIT**

- CPU is partitioned into Arithmetic Logic Unit (ALU) and Control Unit (CU).
- The function of control unit is to generate relevant timing and control signals to all operations in the computer.
- It controls the flow of data between the processor and memory and peripherals

#### **FUNCTIONS OF CONTROL UNIT**

- The control unit directs the entire computer system to carry out stored program instructions.
- The control unit must communicate with both the arithmetic logic unit (ALU) and main memory.
- The control unit instructs the arithmetic logic unit that which logical or arithmetic operation is to be performed.
- The control unit co-ordinates the activities of the other two units as well as all peripherals and auxiliary storage devices linked to the computer.

## **DESIGN OF CONTROL UNIT**

Control unit generates control signals using one of the two organizations:

- Hardwired Control Unit
- Micro-programmed Control Unit

- It is implemented as logic circuits (gates, flip-flops, decoders etc.) in the hardware.
- This organization is very complicated if we have a large control unit.
- In this organization, if the design has to be modified or changed, requires changes in the wiring among the various components. Thus the modification of all the combinational circuits may be very difficult.

#### **ADVANTAGES**

- Hardwired Control Unit is fast because control signals are generated by combinational circuits.
- The delay in generation of control signals depends upon the number of gates.

#### DISADVANTAGES

- More is the control signals required by CPU; more complex will be the design of control unit.
- Modifications in control signal are very difficult. That means it requires rearranging of wires in the hardware circuit.
- It is difficult to correct mistake in original design or adding new feature in existing design of control unit.

#### ARCHITECTURE OF HARDWIRED CONTROL UNIT



Maninder Kaur

professormaninder@gmail.com

www.eazynotes.com

Control unit consist of a:

- Instruction Register
- Number of Control Logic Gates,
- Two Decoders
- 4-bit Sequence Counter

- An instruction read from memory is placed in the instruction register (IR).
- The instruction register is divided into three parts: the I bit, operation code, and address part.
- First 12-bits (0-11) to specify an address, next 3-bits specify the operation code (opcode) field of the instruction and last left most bit specify the addressing mode I.

I = o for direct address

I = 1 for indirect address

- First 12-bits (0-11) are applied to the control logic gates.
- The operation code bits (12 14) are decoded with a 3 x 8 decoder.
- The eight outputs ( D<sub>0</sub> through D<sub>1</sub>) from a decoder goes to the control logic gates to perform specific operation.
- Last bit 15 is transferred to a I flip-flop designated by symbol I.

- The 4-bit sequence counter SC can count in binary from 0 through 15.
- The counter output is decoded into 16 timing pulses
   T₀ through T₀.
- The sequence counter can be incremented by INR input or clear by CLR input synchronously.

### For example:

Consider the case where SC is incremented to provide timing signals  $T_{\alpha}T_{1}T_{2}T_{3}$  and  $T_{4}$  in sequence. At time  $T_{4}$  SC is cleared to 0 if decoder output  $D_{3}$  is active. This is expressed symbolically by the statement:

$$D_3 T_4$$
:  $SC \leftarrow o$ 

 The timing diagram shows the time relationship of the control signals.

- A micro-programmed control unit is implemented using programming approach. A sequence of micro-operations are carried out by executing a program consisting of micro-instructions.
- Micro-program, consisting of micro-instructions is stored in the control memory of the control unit.
- Execution of a micro-instruction is responsible for generation of a set of control signals.

- A micro-instruction consists of:
  - One or more micro-operations to be executed.
  - Address of next microinstruction to be executed.

**Micro-Operations:** The operations performed on the data stored inside the registers are called *micro-operations*.

 Micro-Programs: Microprogramming is the concept for generating control signals using programs. These programs are called micro-programs.

- Micro-Instructions: The instructions that make micro-program are called *micro-instructions*.
- Micro-Code: Micro-program is a group of microinstructions. The micro-program can also be termed as micro-code.
- Control Memory: Micro-programs are stored in the read only memory (ROM). That memory is called control memory.

#### ADVANTAGES

- The design of micro-program control unit is less complex because micro-programs are implemented using software routines.
- The micro-programmed control unit is more flexible because design modifications, correction and enhancement is easily possible.
- The new or modified instruction set of CPU can be easily implemented by simply rewriting or modifying the contents of control memory.
- The fault can be easily diagnosed in the micro-program control unit using diagnostics tools by maintaining the contents of flags, registers and counters.

#### DISADVANTAGES

- The micro-program control unit is slower than hardwired control unit. That means to execute an instruction in micro-program control unit requires more time.
- The micro-program control unit is expensive than hardwired control unit in case of limited hardware resources.
- The design duration of micro-program control unit is more than hardwired control unit for smaller CPU.

## ARCHITECTURE OF MICRO-PROGRAMMED **CONTROL UNIT**

- The address of micro-instruction that is to be executed is stored in the control address register (CAR).
- Micro-instruction corresponding to the address stored in CAR is fetched from control memory and is stored in the control data register (CDR).
- This micro-instruction contains control word to execute one or more micro-operations.
- After the execution of all micro-operations of micro-instruction, the address of next micro-instruction is located.

## COMPARISON BETWEEN HARDWIRED AND MICRO-PROGRAMMED CONTROL UNIT

| Attributes                                | Hardwired Control                                     | Micro-programmed Control                       |  |  |  |
|-------------------------------------------|-------------------------------------------------------|------------------------------------------------|--|--|--|
| Speed                                     | Fast                                                  | Slow                                           |  |  |  |
| Cost of<br>Implementation                 | More                                                  | Cheaper                                        |  |  |  |
| Flexibility                               | Not flexible, difficult to modify for new instruction | Flexible, new instructions can easily be added |  |  |  |
| Ability to Handle<br>Complex Instructions | Difficult                                             | Easier                                         |  |  |  |
| Decoding                                  | Complex                                               | Easy                                           |  |  |  |
| Applications                              | RISC Microprocessor                                   | CISC Microprocessor                            |  |  |  |
| Instruction Set Size                      | Small                                                 | Large                                          |  |  |  |
| Control Memory                            | Absent                                                | Present                                        |  |  |  |
| Chip Area Required                        | Less                                                  | More                                           |  |  |  |

# 8085 Microprocessor Architecture

- 8-bit general purpose μp
- Capable of addressing 64 k of memory
- Has 40 pins
- Requires +5 v power supply
- Can operate with 3 MHz clock
- 8085 upward compatible



- System Bus wires connecting memory & I/O to microprocessor
  - Address Bus
    - Unidirectional
    - Identifying peripheral or memory location
  - Data Bus
    - · Bidirectional
    - Transferring data
  - Control Bus
    - Synchronization signals
    - · Timing signals
    - Control signal

## Intel 8085 Microprocessor

- Registers
  - General Purpose Registers
    - B, C, D, E, H & L (8 bit registers)
    - Can be used singly
    - Or can be used as 16 bit register pairs
      - BC, DE, HL
    - H & L can be used as a data pointer (holds memory

address)

- Special Purpose Registers
  - Accumulator (8 bit register)
    - Store 8 bit data
    - Store the result of an operation
    - Store 8 bit data during I/O transfer Address



16

Data

## Flag Register

- 8 bit register shows the status of the microprocessor before/after an operation
- S (sign flag), Z (zero flag), AC (auxillary carry flag), P (parity flag) & CY (carry flag)

| D7 |   |   |    |   |   |   |    |
|----|---|---|----|---|---|---|----|
| S  | Z | X | AC | X | P | X | CY |

#### Sign Flag

- Used for indicating the sign of the data in the accumulator
- The sign flag is set if negative (1 negative)
- The sign flag is reset if positive (0 –positive)

#### Zero Flag

- Is set if result obtained after an operation is 0
- Is set following an increment or decrement operation of that register

10110011 + 01001101 -----1 1 00000000

#### Carry Flag

Is set if there is a carry or borrow from arithmetic operation

- Auxillary Carry Flag
  - Is set if there is a carry out of bit 3
- Parity Flag
  - Is set if parity is even
  - Is cleared if parity is odd

## The 8085 Instructions

- Since the 8085 is an 8-bit device it can have up to 2<sup>8</sup>
   (256) instructions.
  - However, the 8085 only uses 246 combinations that represent a total of 74 instructions.
    - Most of the instructions have more than one format.
- These instructions can be grouped into five different groups:
  - Data Transfer Operations
  - Arithmetic Operations
  - · Logic Operations
  - Branch Operations
  - Machine Control Operations

## The 8085 Instructions

- Since the 8085 is an 8-bit device it can have up to 2<sup>8</sup>
   (256) instructions.
  - However, the 8085 only uses 246 combinations that represent a total of 74 instructions.
    - Most of the instructions have more than one format.
- These instructions can be grouped into five different groups:
  - Data Transfer Operations
  - Arithmetic Operations
  - Logic Operations
  - Branch Operations
  - Machine Control Operations

## Data Transfer Operations

- These operations simply <u>COPY</u> the data from the source to the destination.
- MOV, MVI, LDA, and STA
- They transfer:
  - Data between registers.
  - Data Byte to a register or memory location.
  - · Data between a memory location and a register.
  - Data between an I\O Device and the accumulator.

The data in the source is <u>not changed</u>.

## The LXI instruction

- The 8085 provides an instruction to place the 16-bit data into the register pair in one step.
  - LXI Rp, <16-bit address> (<u>L</u>oad e<u>X</u>tended <u>I</u>mmediate)
  - The instruction LXI B 4000H will place the 16-bit number 4000 into the register pair B, C.
    - The upper two digits are placed in the 1<sup>st</sup> register of the pair and the lower two digits in the 2<sup>nd</sup>.



## The Memory "Register"

- Most of the instructions of the 8085 can use a memory location in place of a register.
  - The memory location will become the "memory" register M.
    - MOV M B
      - copy the data from register B into a memory location.
  - Which memory location?
- The memory location is identified by the contents of the HL register pair.
  - The <u>16-bit contents</u> of the <u>HL register pair</u> are <u>treated</u> as a <u>16-bit address</u> and used to identify the <u>memory location</u>.

## Using the Other Register Pairs

 There is also an instruction for moving data from memory to the <u>accumulator</u> without disturbing the contents of the H and L register.

LDAX Rp

(<u>L</u>oa<u>D</u> <u>A</u>ccumulator e<u>X</u>tended)

- Copy the 8-bit contents of the memory location identified by the <u>Rp register pair</u> into the Accumulator.
- This instruction only uses the BC or DE pair.
- It does not accept the HL pair.

## **Arithmetic Operations**

- Addition (ADD, ADI):
  - Any 8-bit number.
  - The contents of a register.
  - The contents of a memory location.
  - Can be added to the contents of the accumulator and the result is stored in the accumulator.
- Subtraction (SUB, SUI):
  - Any 8-bit number
  - The contents of a register
  - The contents of a memory location
  - Can be subtracted <u>from</u> the contents of the accumulator. The result is stored in the accumulator.

# Arithmetic Operations Related to Memory

- These instructions perform an arithmetic operation using the contents of a memory location while they are still in memory.
  - ADD M
    - Add the contents of M to the Accumulator
  - SUB M
    - · Sub the contents of M from the Accumulator
  - INR M / DCR M
    - Increment/decrement the contents of the memory location in place.
  - All of these use the contents of the HL register pair to identify the memory location being used.

## Arithmetic Operations

- Increment (INR) and Decrement (DCR):
  - The 8-bit contents of any memory location or any register can be directly incremented or decremented by 1.
  - No need to disturb the contents of the accumulator.

## **Logic Operations**

- These instructions perform logic operations on the contents of the accumulator.
  - ANA, ANI, ORA, ORI, XRA and XRI
    - Source: Accumulator and
      - An 8-bit number
      - The contents of a register
      - The contents of a memory location
    - Destination: Accumulator

| ANA<br>ANI | R/M<br># | AND Accumulator With Reg/Mem AND Accumulator With an 8-bit number  |
|------------|----------|--------------------------------------------------------------------|
| ORA<br>ORI | R/M<br># | OR Accumulator With Reg/Mem<br>OR Accumulator With an 8-bit number |
| XRA<br>XRI | R/M<br># | XOR Accumulator With Reg/Mem XOR Accumulator With an 8-bit number  |